AMENDMENTS TO THE CLAIMS 
Claims 3, 11 and 13 have been canceled without prejudice. 

This listing of Claims shall replace all prior versions, and listings, of claims 
in the application: 

LISTING OF CLAIMS: 

1. (currently amended) A boot method for an In-Circuit Emulation system 
having a microcontroller operating in lock-step synchronization with a virtual 
microcontroller, comprising: 

in the microcontroller, executing a set of boot code to substantially carry 
out initialization : 

in the virtual microcontroller, executing a set of timing code to enable the 
lock-step synchronization, wherein the timing code is timed to take the same 
number of clock cycles as the microcontroller uses to execute the boot code, and 
wherein at least one portion of said set of timing code is different from said set of 
boot code, and wherein the boot code is stored within the microcontroller and at 
least one portion of the boot code is inaccessible to the virtual microcontroller; 
and 

simultaneously halting both the microcontroller and the virtual 
microcontroller. 



CYPR-CD01213 
Serial No. 10/001,478 



Page 2 



Examiner: Proctor, J. 
Group Art Unit: 2123 



2. (original) The method according to Claim 1, further comprising copying 
register contents from the microcontroller to corresponding registers in the virtual 
microcontroller. 

3. (canceled) 

4. (currently amended) The method according to Claim 1 , wherein after the 
executing of the boot code, the microcontroller branches to an assembly 
instruction line [[0]]; and wherein after executing the timing code, the virtual 
microcontroller branches to said assembly instruction line [[0]]. 

5. (currently amended) The method according to Claim 1 , wherein prior to 
the executing of the boot code, and prior to executing the timing code, a break is 
set at an assembly instruction line [[0]]. 

6. (previously presented) The method according to Claim 1, wherein the 
boot code comprises protected initialization code that is not accessible to the In- 
Circuit Emulation system. 

7. (currently amended) The method according to Claim 1, further 
comprising: 

prior to the executing of the boot code, and prior to executing the timing 
code, setting a break at an assembly instruction line [[0]]; and 
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wherein after the executing of the boot code the microcontroller branches 
to said assembly instruction line [[0]]; and 

wherein after executing the timing code, the virtual microcontroller 
branches to said assembly instruction line [[0]]. 

8. (currently amended) The method according to Claim 1, further 
comprising: 

prior to the executing of the boot code, and prior to executing the timing 
code, setting a break at an assembly instruction line [[0]]; 

wherein after the executing of the boot code, the microcontroller branches 
to said assembly instruction line [[0]]; and wherein after executing the timing 
code, the virtual microcontroller branches to said assembly instruction line [[0]]; 

copying register contents from the microcontroller to corresponding 
registers in the virtual microcontroller; 

copying memory contents from the microcontroller to corresponding 
memory in the virtual microcontroller; 

wherein after the executing of the boot code, the microcontroller branches 
to said assembly instruction line [[0]]; and 

wherein after executing the timing code, the virtual microcontroller 
branches to said assembly instruction line zero. 



9. (original) The method according to Claim 8, further comprising removing 
the break at said assembly line zefo after copying the register contents and 
copying the memory contents. 
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10. (currently amended) A boot method for an In-Circuit Emulation system 
having a microcontroller operating in lock-step synchronization with a virtual 
microcontroller, comprising: 

resetting the microcontroller and the virtual microcontroller to a halt state; 
setting a break at an assembly instruction line zefe; 
in the microcontroller, executing a set of boot code to substantially carry 
out initialization ; 

in the virtual microcontroller, executing a set of timing code to enable the 
lock-step synchronization, wherein the timing code is timed to take the same 
number of clock cycles as the microcontroller uses to execute the boot code, and 
wherein at least one portion of said set of timing code is different from said set of 
boot code, and wherein the boot code is stored within the microcontroller and at 
least one portion of the boot code is inaccessible to the virtual microcontroller; 

simultaneously halting both the microcontroller and the virtual 
microcontroller by branching to said assembly instruction line zefe; 

copying register contents from the microcontroller to corresponding 
registers in the virtual microcontroller; 

copying memory contents from the microcontroller to corresponding 
memory in the virtual microcontroller; and 

removing the break at said assembly line zefo after copying the register 
contents and copying the memory contents. 

1 1 . (cancelled) 
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12. (currently amended) A boot method for an In-Circuit Emulation system 
having a device under test operating in lock-step synchronization with a virtual 
processor, comprising: 

in the device under test, executing a set of boot code to substantially carry 
out initialization ; 

in the virtual processor, executing a set of timing code to enable the lock- 
step synchronization, wherein the timing code is timed to take the same number 
of clock cycles as the device under test uses to execute the boot code, and 
wherein at least one portion of said set of timing code is different from said set of 
boot code, and wherein the boot code is stored within the device under test and 
at least one portion of the boot code is inaccessible to the virtual processor; and 

simultaneously halting both the device under test and the virtual 
processor. 

13. (canceled) 

14. (previously presented) The method according to Claim 12, further 
comprising copying memory contents from memory coupled to the device under 
test to corresponding memory coupled to the virtual processor. 

15. (currently amended) The method according to Claim 12, wherein after the 
executing of the boot code, the device under test branches to an assembly 
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instruction line [[0]]; and wherein after executing the timing code, the virtual 
processor branches to said assembly instruction line [[0]]. 

16. (currently amended) The method according to Claim 12, wherein prior to 
the executing of the boot code, and prior to executing the timing code, a break is 
set at an assembly instruction line [[0]]. 

17. (previously presented) The method according to Claim 12, wherein the 
boot code comprises protected initialization code that is not accessible to the In- 
Circuit Emulation system. 

18. (currently amended) The method according to Claim 12, further 
comprising: 

prior to the executing of the boot code, and prior to executing the timing 
code, setting a break at an assembly instruction line [[0]]; and 

wherein after the executing of the boot code, the device under test 
branches to said assembly instruction line [[0]]; and 

wherein after executing the timing code, the virtual processor branches to 
said assembly instruction line [[0]]. 

19. (currently amended) The method according to Claim 12, further 
comprising: 

prior to the executing of the boot code, and prior to executing the timing 
code, setting a break at an assembly instruction line [[0]]; 
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wherein after the executing of the boot code, the device under test 
branches to said assembly instruction line [[0]]; and wherein after executing the 
timing code, the virtual processor branches to said assembly instruction line [[0]]; 

copying register contents from the device under test to corresponding 
registers in the virtual processor; 

copying memory contents from the device under test to corresponding 
memory in the virtual processor; 

wherein after the executing of the boot code, the device under test 
branches to said assembly instruction line [[0]]; and 

wherein after executing the timing code, the virtual processor branches to 
said assembly instruction line zefo. 

20. (original) The method according to Claim 19, further comprising removing 
the break at assembly line zero after copying the register contents and copying 
the memory contents. 

21. (original) The method according to Claim 12, wherein the virtual 
processor is implemented in a field programmable gate array. 

22. (new) The method according to Claim 1 , wherein said set of boot code 
comprises proprietary information, wherein said proprietary information 
comprises serial numbers, passwords, and algorithms. 
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23. (new) The method according to Claim 1 , wherein at least one portion of 
the boot code is inaccessible to the virtual microcontroller bv being stored 
internally in said microcontroller. 
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